import copy
import time
from src.data import DataSeq


def Merge(ds, L, R, RightEnd):
    tmpData = copy.copy(ds.data)
    LeftEnd = R - 1
    i = L
    j = R
    k = L
    # import ipdb; ipdb.set_trace()
    while i <= LeftEnd and j <= RightEnd:
        if tmpData[i] < tmpData[j]:
            ds.SetVal(k, tmpData[i])
            i += 1
        else:
            ds.SetVal(k, tmpData[j])
            j += 1
        k += 1
    while i <= LeftEnd:
        ds.SetVal(k, tmpData[i])
        k += 1
        i += 1
    while j <= RightEnd:
        ds.SetVal(k, tmpData[j])
        k += 1
        j += 1


def Sort(ds, L, RightEnd):
    # import ipdb; ipdb.set_trace()
    if RightEnd > L:
        mid = (L + RightEnd) // 2
        Sort(ds, L, mid)
        Sort(ds, mid + 1, RightEnd)
        Merge(ds, L, mid + 1, RightEnd)


def MergeSort(ds,v):
    assert isinstance(ds, DataSeq), "Type Error"

    Length = ds.length
    Sort(ds, 0, Length - 1)
    time.sleep(v)


def create_sort(title, v, l):
    ds = DataSeq(l, sort_title=title)
    ds.Visualize()
    ds.StartTimer()
    MergeSort(ds, v)
    ds.StopTimer()
    ds.SetTimeInterval(0)
    # ds.Visualize()
    time.sleep(3)
    ds.destory()
    return 0
if __name__ == "__main__":
    ds = DataSeq(64)
    ds.Visualize()
    ds.StartTimer()
    MergeSort(ds)
    ds.StopTimer()
    ds.SetTimeInterval(0)
    ds.Visualize()
